Ability to allow json files to replace @responseFile tags with files mapped #764
  Add this suggestion to a batch that can be applied as a single commit.
  This suggestion is invalid because no changes were made to the code.
  Suggestions cannot be applied while the pull request is closed.
  Suggestions cannot be applied while viewing a subset of changes.
  Only one suggestion per line can be applied in a batch.
  Add this suggestion to a batch that can be applied as a single commit.
  Applying suggestions on deleted lines is not supported.
  You must change the existing code in this line in order to create a valid suggestion.
  Outdated suggestions cannot be applied.
  This suggestion has been applied or marked resolved.
  Suggestions cannot be applied from pending reviews.
  Suggestions cannot be applied on multi-line comments.
  Suggestions cannot be applied while the pull request is queued to merge.
  Suggestion cannot be applied right now. Please check back later.
  
    
  
    
The feature allows JSON files being used with @responseFile tags in the doc bloc to replace string content matching @responseFile:path/to/file.json in the content.
This reduces duplication and its more inlined with creating json drafts. Allowing more finer control of API documentation without hurting the overall documenting engine.
Here is what I am doing with this feature locally.
I am creating various json draft 7 versions and replacing the content where needed using replace tags
The main sample.json file
{ "$schema": "https://json-schema.org/draft-07/schema", "$id": "Sample", "description": "The Sample entity", "title": "Sample Entity", "type": "object", "properties": { "id": { "description": "The id of the entity", "type": "number" }, "name": { "description": "The entity name", "type": "number" }, "nested_sample": { "description": "Null when not present else sample", "type": [ null, "@responseFile:responses/nested-sample/nested-sample.json" ] }, "created_at": { "description": "The date time when created", "type": "string", "format": "Rfc3339String", "examples": [ "2019-03-03T00:00:00+00" ] }, "updated_at": { "description": "The Date time when updated", "type": "string", "format": "Rfc3339String", "examples": [ "2019-03-03T00:00:00+00" ] } }, "required": [ "id", "name", "nested_sample", "created_at", "updated_at" ] }The nested-sample.json file
{ "$schema": "https://json-schema.org/draft-07/schema", "$id": "SampleNested", "description": "The Sample entity", "title": "Sample Entity", "type": "object", "properties": { "id": { "description": "The id of the entity", "type": "number" }, "nestedValue": { "description": "Nested Value description", "type": [ "string", "boolean", "number" ] }, "sampleId": { "description": "Parent sample id", "type": "number" }, } }The final sample.json file
{ "$schema": "https://json-schema.org/draft-07/schema", "$id": "Sample", "description": "The Sample entity", "title": "Sample Entity", "type": "object", "properties": { "id": { "description": "The id of the entity", "type": "number" }, "name": { "description": "The entity name", "type": "number" }, "nested_sample": { "description": "Null when not present else sample", "type": [ null, { "$schema": "https://json-schema.org/draft-07/schema", "$id": "SampleNested", "description": "The Sample entity", "title": "Sample Entity", "type": "object", "properties": { "id": { "description": "The id of the entity", "type": "number" }, "nestedValue": { "description": "Nested Value description", "type": [ "string", "boolean", "number" ] }, "sampleId": { "description": "Parent sample id", "type": "number" }, } } ] }, "created_at": { "description": "The date time when created", "type": "string", "format": "Rfc3339String", "examples": [ "2019-03-03T00:00:00+00" ] }, "updated_at": { "description": "The Date time when updated", "type": "string", "format": "Rfc3339String", "examples": [ "2019-03-03T00:00:00+00" ] } }, "required": [ "id", "name", "nested_sample", "created_at", "updated_at" ] }